<template>
    <el-card style="width: 500px;">
        <el-form label-width="80px" size="small">
            <el-upload
                    class="avatar-uploader"
                    action="http://127.0.0.1:8160/system/upload/headImage"
                    :show-file-list="false"
                    :on-success="handleAvatarSuccess"
                    :headers="uploadHeaders"
                    :before-upload="beforeUpload"
            >
                <img v-if="form.avatarUrl" :src="form.avatarUrl" class="avatar">
                <i v-else class="el-icon-plus avatar-uploader-icon"></i>
            </el-upload>

            <el-form-item label="用户名">
                <el-input v-model="form.username" disabled autocomplete="off"></el-input>
            </el-form-item>
            <el-form-item label="昵称">
                <el-input v-model="form.nickname" autocomplete="off"></el-input>
            </el-form-item>
            <el-form-item label="邮箱">
                <el-input v-model="form.email" autocomplete="off"></el-input>
            </el-form-item>
            <el-form-item label="电话">
                <el-input v-model="form.phonenumber" autocomplete="off"></el-input>
            </el-form-item>
            <el-form-item label="地址">
                <el-input type="textarea" v-model="form.address" autocomplete="off"></el-input>
            </el-form-item>
            <el-form-item>
                <el-button type="primary" @click="save">确 定</el-button>
            </el-form-item>
        </el-form>
    </el-card>
</template>

<script>
    import {getUserByName, updatePersonUser, updateUser} from '@/api/system/user'
    export default {
        name: "Person",
        data() {
            return {
                uploadHeaders:{"Authorization":"bearer " + (localStorage.getItem("token") ? localStorage.getItem("token") : '')},
                form: {},
                user: localStorage.getItem("user") ? JSON.parse(localStorage.getItem("user")) : {}
            }
        },
        created() {
            this.getUser().then(res => {
                this.form = res
            })
        },
        methods: {
            async getUser() {
                return (await getUserByName(this.user.username)).data
            },
            save() {
                updatePersonUser(this.form).then(res => {
                    if (res.code === 200) {
                        this.$message.success("保存成功")
                        // 更新浏览器存储的用户信息
                        this.getUser().then(res => {
                            localStorage.setItem("user", JSON.stringify(res))
                            this.$store.commit("changeAvatarUrl")
                        })
                    }
                })
            },
            handleAvatarSuccess(res) {
                this.form.avatarUrl = res.data
                console.log(res.data)
            },
            beforeUpload(){
                this.uploadHeaders ={"Authorization":"bearer " + (localStorage.getItem("token") ? localStorage.getItem("token") : '')}
            },
        }
    }
</script>

<style>
    .avatar-uploader {
        text-align: center;
        padding-bottom: 10px;
    }

    .avatar-uploader .el-upload {
        border: 1px dashed #d9d9d9;
        border-radius: 6px;
        cursor: pointer;
        position: relative;
        overflow: hidden;
    }

    .avatar-uploader .el-upload:hover {
        border-color: #409EFF;
    }

    .avatar-uploader-icon {
        font-size: 28px;
        color: #8c939d;
        width: 138px;
        height: 138px;
        line-height: 138px;
        text-align: center;
    }

    .avatar {
        width: 138px;
        height: 138px;
        display: block;
    }
</style>
